This Page Is Inserted by IFW Operations 
and is not a part of the Official Record 



BEST AVAILABLE IMAGES 

Defective images within this document are accurate representation of the original 
documents submitted by the applicant. 

Defects in the images may include (but are not limited to): 

• BLACK BORDERS 

• TEXT CUT OFF AT TOP, BOTTOM OR SIDES 

• FADED TEXT 

• ILLEGIBLE TEXT 

• SKEWED/SLANTED IMAGES 

• COLORED PHOTOS 

• BLACK OR VERY BLACK AND WHITE DARK PHOTOS 

• GRAY SCALE DOCUMENTS 

IMAGES ARE BEST AVAILABLE COPY 



As rescanning documents will not correct 
images, please do not report the images to the 
Image Problem Mailbox. 



JEuropaisches Patentamt 
European Patent Office © Publication number 

Office europeen des brevets 

© EUROPEAN PATENT APPLICATION 

© Application number: 89201248.5 © Int. CI. 5 : G05B 19/417 



© Date of filing: 17.05.89 



© Date of publication of application: 


© Applicant: N.V. Philips' Gloeilampenfabrleken 


22.11.90 Bulletin 90/47 


Groenewoudseweg 1 




NL-5621 BA Eindhoven(NL) 


© Designated Contracting States: 


© Inventor: Biemans, Franciscus Petrus Maria 


DE FR GB IT SE 




c/o INT. OCTROOIBUREAU B.V. Prof. 




Holstlaan 6 




NL-5656 AA Elndhoven(NL) 




Inventor: Sjoerdsma, SJoerd 




c/o INT. OCTROOIBUREAU B.V. Prof. 




Holstlaan 6 




NL-5656 AA Eindhoven(NL) 




© Representative: Strijland, Wilfred et al 




INTERNATIONAAL OCTROOIBUREAU B.V. 




Prof. Holstlaan 6 




NL-5656 AA Eindhoven(NL) 



© Work station controller module. 



© A work station controller module for use in an industrial manufacturing system is described. The manufactur- 
ing system is hierarchically organized. A superior level is covered by a host machine, a lower level by 
automation modules that fulfill the manufacturing and transport primitives. The controller module receives higher 
level commands for decomposition into lower level commands. It also receives lower level status signals for 
aggregation to higher level status signals. It also exchanges product exchange requests and product exchange 
acknowledgements with a product transfer system. It further receives operation names and process data from a 
product development system and status aggregation rules and command decomposition rules from a product 
prepation system. These rules govern the decomposition/aggregation cited earlier. 
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Work station controller module. 



BACKGROUND TO THE INVENTION 

The invention relates to a controller module for use in a work station, in particular an industrial work 
station which is an element of a manufacturing control system. Manufacturing, in its broadest sense, 

5 encompasses various primitive, and undivided, operations on a product, such as test, storage or transforma- 
tion. A work station thus comprises a controller module and one or more execution modules. An execution 
module may influence or observe the product in its environment; the product may thus be changed in this 
environment. A work station controller module as recited supra has been described by Scott and Strauss, 
"Work station control in a computer integrated manufacturing system", National Bureau of Standards, 

w Washington, D.C., May 1984. Like the reference, the controller module of the present invention is adapted 
for use in transforming discrete products of all type. Transformation may be realized in manufacturing 
operations of all kinds, such as changing the product shape, assembling, modifying physical properties, 
sorting, testing, moving, packaging, combining and many others. 

15 

SUMMARY TO THE INVENTION 

The inventors have realized that in such product transformation environments it is often possible to 
identify general tasks which are applicable to many different types of product transformation, so that the 
20 organization of the control could be independent of either product type or transformation type. Examples of 
such general tasks are: 

- management of product availability (before, during and after transformation) which is tantamount to stock 
control; 

- coordination among various transformation facilities, such as successive or parallel batch processing 
25 elements, merging and splitting of product streams; 

- updating of various material properties (mechanical, dimensional, chemical, physical, electrical, etcetera); 

- execution of the product transformations proper. In particular in this latter case, the controller module is 
rendered general-purpose by the extensive application of parameter/operation parametrization. Such para- 
metrization may also be usefull to the three earlier aspects, but the embodiment hereinafter specifically 

30 relates to the product transformation parametrization. 

In consequence, among other things it is an object of the invention to provide a work station controller 
that be applicable in general purpose situations, allows for a hierarchical transformation organization, may 
be used as a module in a multi-module system, is easy to reconfigure and to install, for a variety of 
products/transformations/ production scale. The object according to a first aspect thereof, is realized by the 

35 invention in that it provides a work station controller module for controlling a work station and comprising 
processor means interconnected to storage means for on the basis of predetermined operation-linked 
process data and under control of higher level commands and lower level status signals producing lower 
level commands and higher level status signals, said work station controller module further comprising: 

- first bidirectional communication means for receiving said higher level commands from and transmitting 
40 said higher level status signals to a host device; 

- second bidirectional communication means for receiving said lower level status signals from and 
transmitting said lower level commands to one or more product processing automation modules; 

- third bidirectional communication means for transmitting product exchange requests and receiving product 
exchange acknowledgements with respect to any access point the work station has in common with a 

45 product transfer system or with at least one other work station; 

first receiving means for receiving operation names and process data from a product development system; 
second receiving means for receiving status aggregation rules for aggregating said lower level status 
signals to said higher level status signals and command decomposition rules for decomposing said higher 
level commands to said lower level commands from a product preparation system. 

so Various further aspects of the invention are recited in dependent Claims. 

Among other elements, the following are notable advantages of applying the invention: 

- there exists a separation between the generation of the commands on the one side and the strategy of 
their execution, on the other; for one, this allows the host device to abstract from, or even ignore execution 
problems on a lower level; 

- a work station controller module may interpret the strategy of execution that is presented in a recipe; for 
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each product there is a recipe, its execution depending on both the commands from the host and the actual 
status of the work station; this methodoly enhances flexibility; 

- the execution proper of a command may be rendered dependent of both the applicable recipe, and the 
actual control by the higher level, such as represented by suspend and cancel commands, and their 

s respective inverses; 

- the work station controller module is standardizable through its general purpose applicability; it is suitable 
for integration because it has only few interfaces, it has excellent control features through operation, 
suspend, continue, cancel commands in addition to provision of status information and command accept 
acknowledgement, it has good reproducibility through commands for serially repetitive execution, and high 

io performance through parallel execution of commands, safety through alarm handling capability, simplicity 
through exclusion of superfluous functionality, easy application-dependent applicability through input of 
recipes, of addresses of the transport system, of automation module entry points, and of an initial world 
model; 

- the work station controller module can control multiple operational domains, provided only, that the 
T5 processing facilities and/or storage capability were sufficiently therefor. Such multiple domains could relate 

to serially disposed automation modules in a single production stream (possibly separated by a transport 
facility or a temporary buffer), to correspondingly disposed automation modules in parallel production 
streams, or even to completely unrelation manufacturing/testing/etcetera operations. The internal organiza- 
tion could then occur on the basis of time-multiplex, job-multiplex, interrupt-d riven or requests according to 
20 respective priority levels with associated arbitrage. 



BRIEF DESCRIPTION OF THE FIGURES 

as The invention will be explained in detail with respect to the accompanying Figures, wherein 
Rgure 1 shows a conceptual environment of the work station controller module; 
Figure 2 is a detailed block diagram of the work station and its close environment; 
Figure 3 shows the functional set-up of the command decomposition versus the status aggregation. 

30 

DESCRIPTION OF AN OPERATION ENVIRONMENT 

Figure 1 shows a conceptual environment of the work station controller module. Rectangular blocks 
represent functional entities. Blocks with rounded corners indicate the category of questions that the 

35 associated hardware and software level solves. Now, block 60 is the overall control system, herein the 
policy (62) is determined, such as product mix, quality levels, intermediate storage levels. One or more host 
subsystems 64, 66 interact with the overall control system and possibly, with each other. In general, the 
host level decides (68) where and when the various activities, such as product transformations are to be 
executed. Block 70 symbolizes the work station controller module. On a hardware level, this controller 

40 module is realized as a general purpose computer with appropriate processor means interconnected to 
storage means and suitable programming for executing its technical industrial task. A standard solution 
would be the Digital Equipment Corporations VAX machine series. Of late, IBM's computer PS/2 would be 
suitable. The interconnections between various subsystems in Figure 1 may be executed as point-to-point 
lines, as a single network such as VME, Ethernet, or with other means according to requirements. For 

45 brevity, no further explanation of the hardware is given. The work station controller 70 interacts with its own 
host 66. if required with other work station controller modules 71 and, among other things, comprises 
aggregation module 74. In general, the work station controller module solves the question how various 
changes should be effected, that is. to what quantitative and/or qualitative degree. On the lowest level, 
automation modules, to wit processing module (78) and transport module 80 directly interact with an 

so identified product 84 or amount of product, and with their work station controller 70. The process 
identification is symbolized by block 82. As explained elsewhere, processing includes modifying the 
product, testing the product, repairing the product, detecting the product's position or orientation and other 
such primitive operations. 

Figure 2 is a detailed block diagram of the work station and its close environment. The architecure is 
55 described in terms of 'processes 1 : black boxes that accept and generate information. 

If the workstation controller performs two activities in parallel, the architecture is described as a 
multiprocessing organization (single or plural procesors) each process executing one activity. 

The workstation controller 22 is designed as a set of four parallel processes, the so-called H Module 27, 
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G Module 23, M Module 25, and A module 21. The functions of these modules are: 

1. The H Module 27 accepts commands from a host 20, reports back to the host whether or not the 
commands are accepted or rejected, issues sub-commands to automation modules 24, 26, 28 and 
messages to the transport system 30, 32 or to other work station controllers to negotiate the exchange of 
5 products. To that end, the H Module, inter alia: 

- accepts commands. 

- when required, executes recipes v/hich prescribe which actions have to be carried out by the automation 
modules in order to fulfil commands. 

- manages recipes. 

io 2. The M Module 25 maintains a model description of the subordinate automation modules 24. 26, 28 

and that part of the environment that is within the domain of the work station. That model ('world model') 
contain such information as the configuration of automation modules, their capabilities and capacities, the 
products and tools inside the domain of the work station. Such information is used, for example, by the H 
Module to decide to which automation module a command can best be issued. 

75 3. The G Module 23 collects and processes/aggregates status signals from the automation modules 

24, 26, 28 in order to keep the world model of the M Module as consistent as possible with the real world. 
The G Module of a work station controller ensures, for example, that the world model contains up-to-date 
information on the products that are present in the workstation's domain (which products and where). The G 
Module also provides the host 20 with status signals. The status offered to the host is so called 'aggregate 

20 status': status about the workstation in total as opposed to status of individual automation modules. Suppose 
that one automation module has a defect so that the workstation can no longer execute a certain operation. 
The manager system 60 should only be informed that the workstation can no longer execute that operation; 
it does not have to know which automation module is the cause. The G Module also has to establish 
whether or not some status gives rise to an alarm. In case of alarm, the G module suspends the H module 

25 in that commans are accepted from the host, but lower level commands are no longer given to the 
automation modules, as long as the alarm prevails. 

In addition to these three modules, there is a manager A, 21. The manager offers to H, M and G 
Modules 23, 25, 27 parameter values that are characteristic for a particular application and that may vary in 
time. 

30 In Figure 2, the various 'streams' of communications are indicated by 'gates', letters. Processes that 
have one or more gates in common can communicate, as follows: 
" - update, status request 

m : values from manager to H Module, or values from manager to G Module, or values from manager to M 
Module. 

35 a : messages from/to automation modules (38). 

t : messages from/to transport system (42). 

w : messages from/to host (36). 

r : recipes from development system (31). 

f : formulae from development system (29). 
40 s : status to and from M Module 

Finally, the Figure 2 shows the product 34 as being operated by the automation modules 24. 26, 28 

(inclusive of test module 28) and transport system 30. 32. 

The H module 27 is initialized in that it receives the following application-dependent data from host 20: 

- Its potential activity. This is a set of Operation Descriptors, that are activated when the controller module 
45 itself is activated. Some are selfterminating, others would remain active permanently. 

- The autonomous operations. This is a further set of Operation descriptors, that are activated when the 
controller module itself is activated. Some are self- terminating, others would remain permanently active. 

- The Partners. This is a set of addresses of its automation modules 24, 26, 28 and the address of the work 
station controller. After receiving these information the H module is controlled for thereby upstarting the 

so whole work station controller 22. 

2. The H module behaves as three concurrent processes: 

a. - ACCEPT COMmands process: Operation Commands, Suspend Commands, Continue Commands 
and Cancel Commands destined for the workstation are received from host 20. The Operation Commands 
are either accepted or rejected. The accepted ones are kept for execution. The Suspend. Continue and 

55 Cancel Commands are executed. An Operation Command is passed to EXECute COMmandS process for 
execution. 

b. - EXECute COMmandS process: The Operation Commands are executed. EXECute COMmandS 
will process and consider recipe lines for evaluation and execution. 
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c. - RECIPE MANAGER process: The recipes are maintained, updated or deleted. 
The latter three activities are discussed in more detail below. 
ACCEPT COMmandS maintains the following data for the purposes of administration: 

- A set of Operation Commands. The set of Operation Commands contains the Operation Commands that 
5 ^ executed by the work station. The Repeat Number of the Operation Command indicates the number of 

Operations that can still be suspended or cancelled. 

Suppose, for example, that an Operation Command be executed 10 times, if the work station controller 
has started the execution of the first Operation out of the series of ten, nine Operations can still be 
cancelled or suspended. The Operation Command should then contain the repeat number '9\ 
jo - A first set of Entry Codes of the operations that are suspended. 

- A further set of Entry Codes Entry of the operations that are cancelled. 



ACCEPT COMmandS: 

75 

1. either, receives an Operation Command destined for the work station. It then inspects the Potential 
Activity to decide whether or not the operation can be executed. If it cannot be executed, the process 
ACCEPT COMmandS will return a Rejection Indication to host 20. The Rejection Indication contains the 
Entry Code of the rejected Operation Command. If the operation is accepted, the process ACCEPT 

20 COMmandS concurrently: 

- responds to the host with an Acceptance Indication which contains the Entry Code of the accepted 
Operation Command. 

- issues the Operation Description and Entry Code contained in the Operation Command to the process 
EXECute COMmandS. for execution of the operation. Next, a new Operation Command is inserted in the set 

25 of Operation Commands. 

2. or, receives a Suspend Command destined for the work station. It then inspects the set of 
Operation Commands to establish whether or not the Operation Command with the same Entry Code as the 
Suspend Command can still be suspended because of the number of operations to be executed one or 
more had not been started yet. 

30 - If so, it returns a Suspend Indication, which contains an Integer that states how many times an operation 
will be suspended. This integer can be derived from the Operation Command with the correct Entry Code in 
the set of Operation Commands (repeat number). Next, the module inserts the Entry Code in the set of 
Entry Codes of suspended operations, 

- If no suspend is possible, it returns a Suspend Indication with parameter zero. 

35 3. or, receives a Continue Command destined for the work station. It will then remove the Entry Code 

contained in the Continue Command from the set of Entry Codes of Suspended Operations. If this Entry 
Code is not present there, this set remains unchanged. 

4. or. receives a Cancel Command destined for the work station. It then inspects the set of Operation 
Commands to establish whether this command may be cancelled because of the number of operations to 

40 be executed (one or more) had not been started yet 

- If so, it returns a Cancel Indication. The Cancel Indication Contains an Integer that states how many times 
an operation will be cancelled. This repeat number is derived from the set of Operation Commands. It then 
inserts the Entry Code in the set of Entry Codes of cancelled operations and removes (if present) the Entry 
Code from the set of Operation Commands and removes the Operation Command concerned from the set 

45 of Operation Commands. 

- If cancelling is impossible, it returns a Cancel Indication with the integer zero. 

5. or, it receives from the process EXECute COMmandS. which is executing accepted Operation 
Commands, a request to report whether or not a certain Entry Code belongs to those Operation Commands 
that 

so - should still be executed or are completed (with respect to the repeat number that tells how often an 
execution should be repeated), or 

- have been suspended, or 

- have been cancelled. 

Having reported this. ACCEPT COMmandS. 
55 o if the operation has been cancelled and the repeat number is still greater than zero, removes the Entry 
Code from the set of cancelled Entry Codes. 

o if the operation has not been cancelled, and has not been suspended, and the repeat counter is still 
greater than zero, decrements the repeat number. 
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o if the operation has not been cancelled, has not been suspended and the repeat counter is less than or 
equal to zero, issues a Progress Indication to the host with the progress status 'ready', and removes the 
Operation Command from the set of Operation Commands, and the Entry Code from the set of suspended 
and cancelled Entry Codes. 

5 o if the operation has not been cancelled, the repeat number is still greater than zero, but the operation has 
been suspended, does not change the set of Operation Commands, nor the sets of suspended and 
cancelled Entry Codes. 

6. or. ACCEPT COMmandS receives an indication that the execution of an Operation with a certain 
Entry Code has been blocked from the process EXECute COMmandS (meaning that the search for a 
w Recipe Line that can be processed takes too much time). 

- ACCEPT COMmandS searches for the Operation Command with this Entry Code in the set of Operation 
Commands, and then issues a Progress Indication to the host 20 that contains the Entry Code and the 
Progress Status 'blocked'. 

After execution of any of steps 1 through 6. a next step can be executed thereof. 

75 

EXECute COMmandS 

The process EXECute COMmandS ; 
20 1. Either, receives an Operation Description and an Entry Code from ACCEPT COMmandS, 

2. or takes one of the Operation Descriptions of the set of autonomous operations; then receives a 
Recipe suitable for the execution of the Operation Command. Any Recipe is accepted from the process 
RECIPE MANAGER, if that the Operation Descriptions Recipe and of the Operation Command are equal. 
EXECute COMmandS then makes the actualised Recipe available for the Operation Command, then 

25 executes this Recipe as many times as required. 

3. Concurrently, accepts an Operation Command and processes these as discussed in item 1 and 2. 
(Hence, the work station controller can execute an infinite number of commands in parallel). 



30 The Execution Of A Recipe 

Below, the execution of a recipe, for the fulfillment of a commanded operation is discussed first. Next, 
the execution of a recipe for an autonomous operation is discussed. 

1 . First, ACCEPT COMmandS is asked (by reference to the Entry Code) whether the operation is 
35 cancelled, suspended or should still be repeated. 

- If cancelled, the execution of the recipe stops. 

- If the operation should be no longer repeated, the execution of a recipe stops. 

- If suspended, the behaviour detailed here is repeated. 

- If not cancelled, nor completed nor suspended, the execution continues. 

40 2. If the execution of a recipe is continued, a Recipe Line suitable for processing is selected. 

1. All lines of the Recipe with the required Step Number are candidates for processing. When the 
execution of a Recipe is started, a line with Step Number 'inif is searched for. There is a set of lines with 
the correct step number. One line of them has to be executed. First, one of them, suitable for execution is 
selected for evaluation. 

45 First, the M MODULE is asked whether or not there is an alarm. If so, the activities detailed under 2 
(here) are repeated. Else, evaluation of Recipe Lines continues. 

The M MODULE is dedicatd exclusively, so that only the process EXECute COMmandS has access to 
the world model for the processing of this recipe line. The set of conditions of this line and its Update 
Status Instructions and its Move Status Instructions are passed to the M MODULE. This process checks 
so whether or not all conditions of the recipe line with respect to the contents of the world model are true. If 
these conditions are true, the M MODULE 25 will execute the (recipe line) Update Status and Move Status 
Instructions. Finally, the M MODULE will report whether or not the conditions were true (and consequently, 
whether or not the instructions were executed). 

Next, the Send Message Instructions of the recipe line will be executed by the process EXECute 
55 COMmandS in an arbitrary order. 

EXECute COMmandS will send each message to its destination: If the message is destined for an 
automation module, EXECute COMmandS also requests the M MODULE 25 to accept a Status element 
with the variable 'receiver of the message, the operation the message is referring to* and one of the 
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following values: 

o if the message is an Operation Command, the value 'issued 1 , 
o if the message is a Reset Command, the value 'reset*. 

If the message is destined for the transport system, EXECute COMmandS also requests the M 
s MODULE to accept an element with the variable 'accesspoint 1 and one of the following values: 
o if the message is a 'Control Passed' message, the value 'noBodyV 

o if the message is a 'Control Workstation Transport System Request' message, the value 'issued'. 

If the message is destined for the host 20 (progress indication or status indication), this message is sent 
to the host without updating the world model. Next, 
jo - if the next step number of the executed line is 'exit 1 , no further recipe line is executed. 

- if the next step number of the executed line is not 'exit', the activities detailed under 2.1 are repeated with 
the group of lines with this next step number. 

- K the conditions were not fulfilled, the instructions had not been executed, and a subsequent line (possibly 
the same) with the same step number is considered for evaluation and execution. 

js 2. If, after a certain time out period, no Recipe Line has been selected, EXECuteRECipe may decide to 
issue an indication to ACCEPT COMmandS to report that the operation with a certain Entry Code is 
blocked. The searching for a Recipe Line as described above continues. 

The processing of a recipe for autonomous operations occurs in a similar way, except for: 

- suspension, canceling and repetition of the execution of a recipe are not considered. 
20 - there is no time out period. 

The recipe manager has to: 

1 . Either, process a recipe update request. 

- receive an update request (from the product preparation sysem) that contains a recipe. If this recipe 
replaces an existing recipe because it has the same recipe description, delete the existing one and insert 

25 the recipe contained in the update. 

2. Or, process a recipe delete request. 

• receive a delete request (from the product preparation system) that defines the recipe identification of the 
recipe that should be deleted. 

- then, if a recipe with this identification is present, delete the recipe. 
30 3. Or, delete one recipe on own initiative. 

- delete one of the recipes managed by the recipe manager. This is to control the deletion of recipes due to 
limited memory space. _ w „ 

4. Or. offer the process EXECute COMmandS a recipe that is required by the process EXECute 

COMmandS. 

35 When any activity (1 . 2, 3 or 4) is finished, RECIPE MANAGER can execute a subsequent one. 



The G MODULE: 

40 1. first initialises. The following application-dependent dat are received from the WORKSTATION 

CONTROLLER MANAGER, 21 . 

- a set of Status Request Information Tuples, which prescribe the status that should be monitored by the 

workstation controller. 

- The Partners. This is a set of addresses of its automation modules, the address of the transport system 
45 and the address of the workstation controller itself. 

- The locations. These are the Variables of status elements that describe the places at which products or 

tools may reside. 

- The access points where products and tools may enter or leave the workstation controller area. 

2. then, behaves as five concurrent processes: 
so - RECeiVe STATus and EXECute STATus: Status Indications from Automation Modules are received by 
RECeiVe STATus and presented to EXECute STATus. EXECute STATus updates the world model and 
determines which aggregated status is to be sent to the host and/or world model. The relationship between 
received status and other statuses kept in the world model and aggregated status is given in the formulae. 

- In addition. RECeiVe STATus issues Status Requests to Automation Modules. 
55 - FORMULA MANAGER: 

The formulae are maintained, updated or deleted. 

- PROVIDE STATus Status Requests from the host are responded to 

- TRANSFER RESOURCE CONTRol: 
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Messages are exchanged with the transport system to control product transfer between work station and 
transport system or between two work stations. 

RECeiVe STATus. EXECute STATus, PROVIDE STATus, FORMULA MANAGER and TRANSFER 
RESOUCE CONTRol are detailed in the following sections. 



RECeiVe STATus 

Using the set of status request information tuples and the addresses of the automation modules and the 
w work station itself as application-dependent data, the process RECeiVe STATus : 

1. Issues Status Requests. It inspects the set of Status Request Information Tuples, and uses the 
Variable and Address in one Tuple to generate a Status Request to an Automation Module. 

2. Receives Status Indications. It receives a Status Indication destined for the work station, and 
presents these to EXECute STATus. In some cases, a special Status Element is generated with the Variable 

75 'sender of the message, the operation that is referred to* and the value: 

- if the message is an Acceptance Indication: 'busy*. 

- if the message is a Rejection Indication: 'rejected 1 . 

- if the message is a Progress Indication: the status of progress. 

20 

EXECute STATus 

EXECute STATus receives Status from RECeiVe STATus and requests the M MODULE to update its 
world model according to this status. Next, the Formula defining the relations between most recently 
25 received status and existing status is selected. The formula contains several formula lines. Each formula 
line consists of one or more conditions and one or more instructions. Each of these lines is evaluated as to 
whether or not all conditions in the line are fulfilled. The evaluation of one formula line is as follows: 
EXECute STATus locks the world M MODULE to ensure exclusive access to the world model. 

The set of conditions of the formula line, its Update Status Instructions and its Move Status Instructions 
30 are passed to the M MODULE. This process checks whether all conditions of the formula line with respect 
to the contents of the world model are true. 

- If so, the M MODULE will execute the Update Status and Move Status Instructions. Finally, the M 
MODULE will report whether or not the conditions were true (and consequently, whether or not the 
instructions were executed). 

35 Next, the Send Message Instructions of the formula line will be sent in an arbitrary order to the host by 
the process EXECute STATus. Next, EXECute STATus unlocks the M MODULE. 

- if any condition is not true, the M MODULE is unlocked. 



40 Alarm Handling 

Alarms can be considered as special cases of aggregate status. Alarm messages if needed have to be 
incorporated in the set of Send Message Instructions of Formulas. 

45 

FORMULA MANAGER 

The formula manager has to: 

1 . Ether, process a formula update request. 

so - receive an update request (from the product preparation system) that contains a formula. 

- then, if this formula replaces an existing formula because it has the same formula description, delete the 
existing one and insert the formula contained in the update. 

2. Or. process a formula delete request. 

- receive a delete request from the product preparation system that defines the formula identification of the 
55 formula that should be deleted. 

- then, if a formula with this identification is present, delete the formula. 

3. Or, offer the process EXECute STATus a formula that is required by the process EXECute 
STATus. 
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When activity 1. 2 or 3 is finished, FORMULA MANAGER can again execute either activity 1. 2 or 3. 



PROVIDE STATUS 

5 

Using the locations and the address of the host as applicatiorv-dependent data, PROVIDE STATus: 
1. receives a Resource Request destined for the workstation. 
- Then, PROVIDE STATus requests the M MODULE to report the identifiers of resources that are located at 
the positions of the 'locations*. 
70 - Then, PROVIDE. STATus counts the number of identifiers that equal the identifier contained in the 
Resource Request, and sends this number to the host in a Resource Indication Message. 



TRANSFER RESOURCE CONTRol 

75 

Using the access points, the locations and the addresses of work station controller module and 
transport system as application-dependent data, TRANSFER RESOURCE CONTRol simultaneously controls 
each of the access points: 

1 . either, it processes control transfer requests from the transport system: 

20 - receives a control transfer request from the transport system directed to the work station controller module 
concerning the access point 

- then, locks the world model and asks the world model manager to insert status that states that the access 
point is claimed by the transport system, provided that in the world model the access point is claimed by 
nobody. 

25 - then, receives from the world model manager, a reply that states whether or not the conditions for 
updating were true and unlocks the world model. 

- If not, a control refused message concerning the access point is returned to the transport system. 

- If so, a control granted message concerning the access point is returned to the access point. 

- Or, TRANSFER RESOURCE CONTRol receives a control passed message concerning the access point. 
30 TRANSFER RESOURCE CONTRol then updates the world model with status that states: 

- the name of the product, as contained in the control passed message, that resides at the location of the 
entry point and associated product data. 

- the fact that no element is claiming control of the access point. 

2. or, receives a control granted message from the transport system concerning the access point. 
35 Next, TRANSFER RESOURCE CONTRol updates the world model with status that states that the control of 

the access point has been granted. 

3. or, receives a control refused message from the transport system concerning the access point. 
Next, TRANSFER RESOURCE CONTRol updates the world model with status that states that the control of 
the access point has been refused, and continues to behave as detailed in 1 , 2 or 3. 

40 

The M MODULE 25: 

1. first initialises. It receives the application-dependent initial world model from the work station 
45 controller manager 21 . 

2. Then, it behaves as WORLD MODEL MANAGER. It manages the world model by processing 
requests for status and updating the model with Status received from both the H and G MODULE. 

WORLD MODEL MANAGER 

50 

The WORLD MODEL MANAGER has to: 

1 . either, receive and process update requests. 
It has been described in sections EXECute COMmand and EXECute a STATus that updates on the world 
model also depend on the current state of this world model. Updating the world model is enabled to at most 
55 one participating process at a time to guarantee the consistency of the world model. This is done as follows 

1. first receive a lock request 

2. next, 1. Either receive and process an Update Status Request, that specifies a status element 
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that should be inserted in the world model. Then, insert this status element and remove the existing status 
element if any, with the same status descriptor as that of the status element contained in the update 
request. 

2. or receive and process a Move Status Request. Assign the Value of the Status element with the first 
5 Variable to the Status Element with the second Variable. The Status element with the first Variable receives 

the Value 'noResourceV 

3. or receive and process conditions and update status commands and indicates whether or not these 
conditions were fulfilled 

- receive a set of conditions and a set of status elements and return a 'true* if the conditions are true with 
70 respect to the world model a, "false" if not. If true, the world model is updated according to the new status 
elements. 

4. or receives and processes conditions and update status or move status commands. If the conditions are 
true, the world model is updated according to the new status elements. 

2. or, receive and process request for one or more Status elements: receive a status request that 
75 specifies a status Variable or a set of Variables, then supply the requested status elements, 

FURTHER ORGANIZATIONAL DESCRIPTION 

20 Figure 3 shows the functional set up of the command decomposition versus the status aggregation. 
Three successive hierarchical levels are shown. The upper one 100 may control the complete production 
line from raw material to finished product. The second level 102 controls the unit product transformation. 
The third level 104 modifies the respective physical entities. The work station controller module 102 is on 
the middle level. Each level has its own world model, which is restricted to the aspects relevant to the level 

25 in question. For example, the lower level knows physical and geometrical aspects of each separate product 
present. The next higher level could know the number of products present without knowing physical details. 
As the situation may require, the number of successive layers may be higher or lower. On their own 
respective level, the world models communicate with command decomposition elements 130, 132, 134 and 
status aggregation elements 110, 112, 114. On each level a composite command may be separated into 

30 more elementary commands. On each level a number of more elementary status signals may be 
aggregated to more composite status signals. For example, an aggregated alarm may be ORed from a 
plurality of elementary alarms. A plurality of elementary stock feed requests is added to a composite stock 
feed request by adding the requested quantities. 

35 

MESSAGES 



Hereinafter, messages are discussed systematically between the host and the work station controller 



40 


name 


communicators 


entry 
code 


further : 




operation command 


x 


X 


operation description, repeat counter 




suspend/continue/cancel commands 


X 


" X 




45 


acceptance/rejectind. 


X 


X 






suspend'cancel ind. 


X 


X 


repeat counter 




resource request 


X 




resource identif. 




resource identifier 


X 




resource ident., integer 




progress indication 


X 


X 


status of progress 


50 


status request 


X 


X 


status variable none 




status indication 


X 




status 



Herein, the -Communicators- define the sender and receiver of the Message. 

1. The Operation Command commands an execution of an operation on resources, and may indicate 
one or more products and one or more operations. 

- The Repeat Counter defines how many times the execution must be repeated. 

- The Entry Code facilitates a reference to an Operation Command. 
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Some relationships with other messages: 

s 

- An Operation Command is accepted or rejected by the work station controller module. In the case of 
acceptance, the latter returns an Acceptance Indication with the Entry Code for reference to the accepted 
Operation Command. In the case of rejection, a Rejection Indication is returned that contains the Entry 
Code. 

jo - Suspend Command, Continue Command and Cancel Command temporarily stop, restart and permanently 
stop the execution of the operation, respectively. 

2. The Suspend Command is used to temporarily stop the execution of an operation, in the sense 
that during the suspension no resources (materials/tools) should be delivered by the workstation. 

75 Parameters: 

- The Entry Code refers to the Operation Command, whose execution is to be suspended. 

- The work station controller reacts to a Suspend Command with a Suspend Indication. 

3. The Continue Command is used to cancel certain Suspend Commands so that the execution of 
20 any suspended operation is continued. 

Parameters: 

- The Entry Code refers to the Operation Command, the execution of which is to be continued. 
25 - The Continue Command deletes a Suspend Command that has the same Entry Code. 

4. The Cancel Command is used to prevent further execution of certain Operation Commands. If the 
operation has not yet started, it will no longer be started. In case the Operation Command commanded a 
series of operations, that part of the series that has not yet started will no longer be executed. 

- The Entry Code refers to the Operation Command, the execution of which is to be cancelled. 

30 

Some relationships with other messages: 

- The Cancel Indication reports the cancellation. 

5. The Acceptance Indication is used by the work station to indicate that it can execute a certain 
35 operation. The operation can be executed if it does not conflict with the (permanent) ability of the work 

station. The presence of tools or materials is not evaluated. 

- The Entry Code refers to the Operation Command that is accepted. 

- The work station controller may also respond to an Operation Command either with an Acceptance 
Indication or with a Rejection Indication. 

40 6. The Rejection Indication is used by the work station to indicate that it cannot execute a certain 

operation because of a permanent inability of the work station. A temporary shortage of tools or materials is 
not signalled. 

- The Entry Code refers to the Operation Command, the execution of which is rejected. 
45 Some relationships with other messages: 

- The Rejection Indication may be a response to an Operation Command as alternative to an Acceptance 
Indication. 

7. The Suspend Indication is used by the work station to report its fulfilment of a Suspend Command, 
so - The Entry Code refers to the Operation Command, the execution of which has been suspended. 

- The Repeat Counter indicates how many operations have been suspended, for possible later execution. 

8. The Cancel Indication is used by the work station to report its fulfilment of a Cancel Command. 

- The Entry Code refers to the Operation Command, the execution of which has been cancelled. 

- The Repeat Counter indicates how many operations have been cancelled. 

55 9. The Resource Request is used by the host to inquire about the number of certain resources 

(materials, tools) present within the domain of control of the work station. 

- The Resource Identifier defines the resource. 

10. The Resource Indication is used by the work station to inform the host about the number of 
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certain resources (materials, tools) present within the domain of control of the work station. 

- The Resource Identifier defines a resource. 

- The Integer indicates the number present. 

- The Resource Indication can be either a response to a Resource Request, or a non-solicited message, 
5 generated by the work station. 

11. The Progress Indication is used by the work station to inform the host about the progress of the 
execution of certain operation commands. The execution can be ready or temporarily blocked, for example 
because of a shortage of materials or tools. 

- The Entry Code refers to an Operation Command, of which the execution progress is reported. 
10 - The Status of Progress (ready'blocked) defines the progress. 

12. The Status Request is used by the host to be informed of (part) of the status of the work station. 

- The Variable refers to the required Status. 

- The Status Indication reports the Status Variable and the actual Status Value. 

13. The Status Indication is used by the work station to inform the host about a certain status. Status 
75 Indication can be provided on command of the host or spontaneously. 

- The Status Indication contains a Status Element. 

2.2 WORK STATION CONTROLLER - AUTOMATION MODULE 
20 The following Messages are exchanged between work station controller module and automation module: 





Name of the message 


communicators 


operation 


further 




OPERATION COMMAND 


X 


X 




25 


RESET COMMAND 


X 


X 






ACCEPTANCE INDICATION 


X 


X 






REJECTION INDICATION 


X 


X 






PROGRESS INDICATION 


X 


X 


status of progress 




STATUS REQUEST 


X 


X 


status variable 


30 


STATUS INDICATION 


X 


X 


status element 



1. The Operation Command is used to command the execution of an operation. 
- The Operation Identifier defines the operation to be executed. 



Some relationships with other messages: 

- An Operation Command is accepted or rejected by the automation module controller, which returns an 
Acceptance indication or a Rejection Indication, respectively. 

- Reset Command can stop the execution of the operation by returing the automation module to a 
predefined state. 

2. The Reset Command is used to disrupt the execution of an operation. 
The automation module returns to a pre-defined state. 

- The Operation Identifier refers to the Operation, the execution of which is to be disrupted. 

3. The Acceptance Indication is used by the automation module to indicate that it can execute a 
certain operation because of permanent ability. 

- The Operation Identifier refers to the Operation Command, the execution of which is rejected. 

- The Acceptance Indication is a response to an Operation Command. 

- The automation module may alternatively respond to an Operation Command with a Rejection Indication. 

4. The Rejection Indication is used by the automation module to indicate that it cannot execute a 
certain operation, because of a permanent inability. 

- The Operation Identifier refers to the Operation Command, the execution of which is rejected. 

5. The Progress Indication is used to report the progress of an operation. The progress can be: 

- 'ready', when the operation is completed, or 

- 'blocked', when the operation is temporarily suspended because of missing materials or tools. 

6. The Status Request is used by the work station controller to be informed of (part) of the status of 
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the automation module. 

- The Variable refers to the required Status. 

7. The Status Indication is used by the automation module to inform the work station controller about 
a certain status. Status Indication can be provided either on the command of the work station controller or 
5 self-reliantly. 

- The Status Indication contains a Status Element. 

2.3 WORKSTATION CONTROLLER - TRANSPORT SYSTEM 

w The work station controller and transport system communicate in order to transfer the control of 
resources (materials, tools). The following control transfer messages are used. 



Name of the message 


communicators 


access 
point 


further 


CONTROL TRANS WORKST REQUEST 


X 


X 




CONTROL WORKST TRANS REQUEST 


X 


X 


CONTROL GRANTED 


X 


X 


CONTROL REFUSED 


X 


X 


CONTROL PASSED 


X 


X 


product, product Data 



The Communicators define the sender and receiver of the Message. The Access Point defines a place 
where products or tools may enter or leave the work station controller's domain of control. 



Short description of the messages: 

1 . The "Control Trans Workst Request" message is used by the transport system to ask the work 
station controller permission to pass control of a product or a tool from the transport system to the work 
station controller. 

2. The Control Workst Trans Request message is used by the work station controller to ask the 
transport system permission to pass control of a product or a tool from the work station controller to the 
transport system. 

3. The Control Granted message is used by a sender to grant permission to pass control of a product 
or tool from the receiver to the sender. 

4. The Control Refused message is used by a sender to refuse permission to pass control of a 
product or tool from the receiver to the sender. 

5. The Control Passed message is used by a sender to acknowledge that control of a product or a 
tool has been passed to the sender. 

In addition to communicators and access points, the Control Passed Message has two parameters: 

1. Product: This concerns all information that is available to the system that has the product under its 
control. An example of such information is the name of a product. 

2. Product Data: This is information so closely associated with a product that the sender of the data 
requests the transport system to transfer the data simultaneously with the product. 



APPLICATION-DEPENDENT DATA 

The work station controller is tailored to its application by provision of pertinent data. In particular, 
'recipes' prescribe how the work station controller should execute certain operations, selection of certain 
materials, a certain configuration of automation modules in its domain etc. 

Application-dependent data as input are separated from the command and status interfaces with the 
host, automation modules and transport system. The reason is that the provision of the application- 
dependent data is not the responsibility of the host. The host determines what is to be done by the work 
station. It does not determine how it is to be done. The host, for example, commands the execution of a 
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particular operation; the recipe prescribes how this operation should be executed. 

'Partners 1 are sets of addresses or names of the subsystems that should communicate. These are, the 
address of the work station itself, of the automation modules, of the transport system and of the host. 

LOCATIONS are a set of Variables of Status elements that refer to places where the work station 
5 controller can locate such resources as material and tools. The work station controller maintains Status 
elements that consist of these Variables and of Values that describe the Identity of the product or tool at 
that location. 

ACCESS POINTS are variables referring to the locations at which products can pass from the transport 
systems domain of control to the work station's domain of control or vice versa. These locations are 
70 controlled by both the transport system and the work station controller. The variables are used by the 
workstation controller itself, and can also be used in recipes to assign the control of a location. 

A WORLD MODEL is contained in the work station controller and gives a model of the state and 
capabilities of its subordinates. Among others, this is needed to reflect the global state of the work station. 
Depending on this state, the work station controller may decide to execute different actions. 
75 At start-up, an initial world model is fed into the work station controller. During operation, the work 
station controller updates this model. 

The model is a set of Status elements. Each Status element consists of a Variable and a Value, for 
example, a location and a product name, saying that a Product is present at a Location. 

20 

SET OF STATUS REQUEST INFORMATION TUPLES 

Because the work station controller should update its world model, it should know which information it 
should collect for this purpose. The updating may occur by issuing appropriate status requests to 
25 automation modules. Therefore, the work station controller needs to receive information that says which 
types of status it has to collect from which automation module. This is defined by a set of so-called Status 
Request Information Tuples. A Status Request Information Tuple contains a Variable and an Address of an 
automation module. 

The work station controller will issue requests to the systems at these addresses to supply the Status 
30 element belonging to the Variable. 



3.6 RECIPES 



35 A recipe is a presciption of how a work station controller should execute a command. A Recipe consists 

of a Recipe Identification and a sequence of one or more Recipe Lines. 

A Recipe Identification is an Operation Description which defines the Operation for which the Recipe 

can be used. A recipe line consists of: 

(Step Number [Conditions (Instructions |Next Step Numberj 
40 1. A step Number identifies a step in the execution of a Recipe. A Recipe Line specified by this Step 

Number will be executed. There may be more than one Recipe Lines with the same Step Number. 

However, only one of the Recipe Lines can be selected for further execution. Which one will be executed 

depends on its Set of Conditions as will be explained below. 

2. A set of Conditions is an assertion about a Status Variable and Value. For example 'temperature 
45 equals 100' consists of a Variable, an Operator and a Norm Value. 

The Variable refers to a Status element in the world model of the work station controller. The work station 

controller compares the Condition with the Status element of the world model, and determines whether or 

not the Condition is satisfied, given the Value of the Status. 

The Operator can be an equal ( = ) or not-equal (#) to the operator and can act upon all sorts of Values. It 
so can also be a less than (<) or greater than (>) operator provided that the Values can be ordered. 

A Recipe Line can only be executed if all Conditions of its set of Conditions are met. The Conditions may 
define more than one assertion about the same Variable, for example: 



temperature < 100 "temperature less than 100" 
temperature > 90 "temperature greater than 90' 

locationl = productx "at locationl is products" 
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3. The Set of Instructions are those that should be executed if the conditions of the recipe line are 

true: 

- Send Message Instruction; the Recipe Instruction consists of a Message that should be sent to its 
5 destination (automation module, host or transport system). Such a message could be, for example, an 

Operation Command for an Automation Module. 

- An Update Status Instruction consists of an Element as discussed earlier. The work station controller will 
update the world model with this Status. 

- Move Status Instruction consists of two Variables. 

70 In order to execute a Move Status Instruction, the work station controller will update the world model, by 
assigning to the status element with the second Variable, the value associated with the first Variable, and 
assign the value 'noResource' to the first Variable. 

Assume, for example, that the world model contains the following two status elements: 



75 



location 1 


Productx 


location2 


NoProduct 



After the execution of the Move Status Instruction, 



locationl location 2 



25 

the world model contains the following two Status elements: 



30 



locationl 


no Resource 


location2 


Productx 



Execution of a move status instruction 
35 The Move Status Instruction is used to update the world model if products have been transported from one 
place in the work station controllers domain to another. 

When a Recipe Line is processed, all Recipe Commands of its Set of Recipe Instructions are executed. The 
order of execution is arbitrary. 

4. Next Step Number identifies the Step Number of a Recipe Line that should be executed next. 
40 There is one special Step number, 'exit 1 which means that there is no next Recipe Line that should be 
executed. 

The following scheme shows the sequence of activities that take place when a recipe is processed. 



45 



50 



55 
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1: select Recipe 
I 

2: actualise Recipe 

i 

3: Step Number := mit 



10 



15 



20 



4: select Recipe Line, 
depending on step and status feedback 

5: process Recipe Line 

6: Step Number := Next Step Number 



<Step Number = exit> 
v 

no 



yes 



-> exit 



1. The work station controller selects a Recipe that has an identifier that matches the Operation 
Description of an Operation Instruction that should be executed. 

The possible forms of matches are: 

1. The Operation Description and the Recipe Identity are identical. 

2. The Product Identifier of the Operation Description lies within the range of Product Identifiers 
specified in the Recipe Identity. 

2. The Recipe has to be actualised. 

The Recipe may contain variables for which actual values should be substituted during processing. These 
variables concern Product Identifiers. Assume, for example, a Recipe Identity of a Recipe for a dispatch 
operation. In the Recipe, the product that is dispatched is referred to by a variable V. Assume that this 
Recipe Identity matches by an Operation Description 'Dispatch product!'. Now, the actualised recipe will 
contain the value *product1' instead of the variable V. 

3. The Step Number of the first Recipe Line that is processed in 'mit'. 

4. A Recipe Line has to be selected for processing. A Recipe Line can only be processed if its Step 
Number has the right value and if all its Conditions are satisfied. The work station controller will inspect its 
world model to decide whether or not all the Conditions of a particular Recipe Line are satisfied. 

If there is more than one Recipe Line with the same Step Number, the work station controller will select one 
for evaulation in an arbitrary order until it finds one Recipe Line that is suitable. If no Recipe Line is eligible 
for execution, the selection will be repeated (changing status conditions may change the suitability of a 
recipe Line for processing). 

5. The selected Recipe Line is Processed. This means that the Recipe Instructions contained in the 
selected Recipe Line have been executed. A Recipe Line may contain more than one Recipe Instruction. 
These are executed in an arbitrary order. There are three types of Recipe Instructions, viz. 

- Send Message Instructions 

- Update Status Instructions 

- Move Status Instructions 

6. The Step Number of the next Recipe Une to be processed is the Next Step Number of the most 
recently processed Recipe Line. If this number is 'exit\ the processing of the Recipe has finished. If not, the 
next Recipe Line has to be processed. 

Simultaneous Use Of Resources By More Than One Recipe 
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Development of a recipe can be considered as the development of a program for a work station 
controller. The variables referred to in the set of conditions of a recipe line are global variables accessible 
for all recipes that are executed, as they are in the world model. 

The work station controller will execute only one recipe line at a time and the next recipe line can only 
s be started if all instructions of a previous recipe line have been executed. 

It may occur that more than one recipe is executed simultaneously and that it is necessary to issue 
commands for a single automation module, space, tool or product. These commands can easily pose 
conflicting claims on it. For example, one recipe requires an automation module to move from A to B 
whereas another recipe requires an automation module to move from A to C. 
jo Such conflicting claims can be avoided if the recipes are programmed correctly. The global character of 
a status variable and the one-by-one execution of recipe lines can be used to this end. 

The following mechanism is used. A recipe may request the updating of status in the world model. 
Status is assumed to consist of a Variable that describes the resources and a Value that describes the 
Identity of a recipe that controls the resource. By updating the Value of such status types, the rights to 
75 control the resource can be tranferred. 

Assume, for example, the variable 'criticalAM* and a recipe with identity 'critical AM User'. The following 
lines of a recipe guarantee that the automation module 'criticalAM' is controlled by the recipe 
'critical AM User' only. 



20 


I 


n 


I 


criticalAM = noRecipe 


I 


US(crittcalAM,criticalAMUser) 




I 


n + 1 


I 










I 
I 


n + 1 


I 
I 




I 




25 
















I 
I 


m 


I 
I 




1 


US(criticalAM .noRecipe) 



30 

The standard value 'noRecipe' indicates that no recipe controls the 'criticalAM'. By executing the 
Update Status Instruction (US), it is indicated that the recipe 'criticalAMUser 1 now controls the automation 
module. 

35 

SET OF OPERATION DESCRIPTIONS 

A work station cannot execute all possible operations. For example, due to a certain physical 
implementation, it cannot execute operatios that require high temperatures. As a consequence, the work 
40 station controller may reject the execution of some operations. 

During start-up. the work station controller should be fed with Descriptions of the operations it can 
execute. There are several ways to determine whether a given operation can be executed. 

45 SET OF AUTONOMOUS OPERATIONS 

Often a work station controller will be able to execute some operations directly upon becoming active, 
that is, without an explicit command from a host. An example is the handling of materials and tools in the 
domain of a work station in order to position these at optimal places, 
so At start-up. the workstation controller should be fed with the Operation Descriptions of these operations. 
Apart from the types of Operation Descriptions mentioned in the previous section, an Operation Description 
can be used that only defines the identifier of an Operation. 



55 FORMULAE 



A Formula is a prescription of how a work station controller should execute a received status element, 
apart from just updating the world model with it. A Formula consists of a Formula Variable and one or more 
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Formula Lines, as follows: 



I Formula Variable 



15 



Formula Line 
Formula Line 
Formula Line 
Formula Line 



20 



25 



30 



A Formula Variable is a Status Variable, its Formula will be processed if a status indication is received 
that contains this variable. 

A Formula Line contains two parts: 

1 . Set of Conditions and 

2. Formula Instructions 

The meaning of these are identical to the meanings of Set of Conditions and Set of (Recipe) 
Instructions of a Recipe. However, the Formula Instructions do not contain messages to be sent to the 
automation modules or transport system. They can contain messages to the host. 



Conditions Instructions 



A Formula is processed as follows: 

1. The work station controller selects a Formula that has a Formula variable matching the received 
Status Variable. 

2. Each formula is evaluated. The instructions of a formula line can only be processed if all 
Conditions are satisfied. The work station controller will inspect its world model to decide whether or not all 
Conditions of a particular Formula Line are satisfied. If this is the case : 

- The selected Formula Line is Processed. As with the instructions in a Recipe Line, this means that the 
Instructions contained in the selected Formula Line are executed. 



Caption listing 

Figure 1: 60 manager: 62 policy; 64. 66 host; 68 when; 70 work station controller; 72 development 
system; 74 status aggregation; 76 how; 78 processing/automation module; 80 transport module; 82 what; 84 
product. 

Figure 2: 20 host; 21 manager module; 22 work station controller module; 23 status management 
module; 25 mode! description module; 72 interaction module; 24, 26, 28 automation modules; 30, 32 
transport system modules; 34 product. 

Figure 3: 100 host level: procedure product from raw material; 102 work station controller level: unit 
product transformation; 104 automation module control level: modifies physical entities; 110, 112, 114 status 
aggregation; 120, 122, 124 world model; 130, 132, 134 command decomposition- 



Claims 

1. A work station controller module for controlling a work station and comprising processor means 
interconnected to storage means for on the basis of predetermined operation-linked process data and under 
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control of higher level commands and lower level status signals producing lower level commands and 
higher level status signals, said work station controller module further comprising: 

- first bidirectional communication means for receiving said higher level commands from and transmitting 
said higher level status signals to a host device; 

5 - second bidirectional communication means for receiving said lower level status signals from and 
transmitting said lower level commands to one or more product processing automation modules; 

- third bidirectional communication means for transmitting product exchange requests and receiving product 
exchange acknowledgements with respect to any access point the work station has in common with a 
product transfer system or with at least one other work station;. 

w first receiving means for receiving operation names and process data from a product development system; 
second receiving means for receiving status aggregation rules for aggregating said lower level status 
signals to said higher level status signals and command decomposition rules for decomposing said higher 
level commands to said lower level commands from a product preparation system. 

2. A work station controller module as claimed in Claim 1 , wherein said work station controller attends 
rs to said host device as first source for therefrom receiving timing signals and quantization signals for work 

station product transform and attends to a second source that may be different from said first source for 
therefrom receiving modality signals for modality controlling said work station product transform. 

3. A workstation controller module as claimed in Claim 1 or 2, comprising four mutually cooperating 
process modules, as follows: 

20 - an interaction module H for receiving and updating said higher level commands, for generating said lower 
level commands, and receiving said lower level status signalling any of initiation/non- 
initiation/termination/non-termination of execution of any of said second lower level commands, for man- 
aging said operation names/process data, and for activating said third communication means; 

- a model description module M for managing model information of a world model, inclusive of parameter 
25 data of said automation module, any assigned product and any assigned tool; 

- a status management module G for receiving and aggregating said lower level status signals to said highe 
level status signals and for checking any actual status to said world model for upon incompatibility 
generating an alarm signal for said interaction module, and 

- a manager module A for specifying 

30 o logical addresses for said host device; 

o allowable physical locations for product/tools; 

o alarm conditions for specifying said incompatibility; 

o and for presenting application-dependent information to said interaction module, said model description 
module, and said status management module. 
35 4. A work station controller module as claimed in Claim 1, and comprising strategy defining means for 
defining a strategy of executing a higher level command as represented by associated lower level 
commands without this higher level command defining such strategy. 

5. A work station controller module as claimed in Claim 1, and comprising checking means for checking 
any higher level command received versus an associated recipe stored locally and upon the result of said 

40 checking specifying any associated lower level command. 

6. A work station controller module as claimed in Claim 1 wherein said higher level commands 
comprise any of the following: suspend, cancel, resume. 

7. A work station controller module as claimed in Claim 6, and comprising specifying means for 
numerically specifying a serially repetitively executable series of operations to be suspended on/or 

45 cancelled. 

8. A work station controller module having multiprocessing facilities for in each of a respective set of 
processes controlling a respectively associated automation module domain. 
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